

Docket No.: 60188-065

# IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

In re Application of

Hirotaka ITO, et al.

Serial No.:

Group Art Unit:

Filed: April 20, 2001

Examiner:

For:

PACKET TRANSMISSION/RECEPTION PROCESSOR

## CLAIM OF PRIORITY AND TRANSMITTAL OF CERTIFIED PRIORITY DOCUMENT

Commissioner for Patents Washington, DC 20231

Sir:

In accordance with the provisions of 35 U.S.C. 119, Applicants hereby claim the priority of: Japanese Patent Application No. 2000-124867, filed April 25, 2000

cited in the Declaration of the present application. A Certified copy is submitted herewith.

Respectfully submitted,

MCDERMOTT, WILL & EMERY

Michael E. Fogar Registration No.

600 13th Street, N.W. Washington, DC 20005-3096 (202) 756-8000 MEF:prp

Date: April 20, 2001

Facsimile: (202) 756-8087



## 日本国特許庁

PATENT OFFICE
JAPANESE GOVERNMENT

別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office.

出 願 年 月 日 Date of Application:

2000年 4月25日

出 願 番 号 Application Number:

特願2000-124867

出 願 人 Applicant (s):

松下電器産業株式会社

2001年 1月26日

特許庁長官 Commissioner, Patent Office





#### 特2000 124867

【書類名】

特許願

【整理番号】

2037820017

【提出日】

平成12年 4月25日

【あて先】

特許庁長官 殿

【国際特許分類】

H04L 12/56

【発明者】

【住所又は居所】

大阪府門真市大字門真1006番地 松下電器産業株式

会社内

【氏名】

伊藤 裕隆

【発明者】

【住所又は居所】

大阪府門真市大字門真1006番地 松下電器産業株式

会社内

【氏名】

田平 由弘

【特許出願人】

【識別番号】

000005821

【氏名又は名称】

松下電器産業株式会社

【代理人】

【識別番号】

100077931

【弁理士】

【氏名又は名称】

前田 弘

【選任した代理人】

【識別番号】

100094134

【弁理士】

【氏名又は名称】 小山

【手数料の表示】

【予納台帳番号】

014409

【納付金額】

21,000円

廣毅

【提出物件の目録】

【物件名】

明細書 1 【物件名】

図面 1

【物件名】

要約書 1

【包括委任状番号】

9601026

【プルーフの要否】

要

#### 【書類名】 明細書

【発明の名称】 パケット送受信処理装置

#### 【特許請求の範囲】

【請求項1】 CPUに接続されたパケット送受信処理装置であって、

外部からバスを介して供給されるパケットを受信するリンクコア回路と、

前記リンクコア回路によって受信された受信パケットに対する処理を行い、前 記受信パケットに対応する送信パケットを作成して前記リンクコア回路に供給す るパケット処理制御回路とを備え、

前記リンクコア回路はさらに、前記パケット処理制御回路からの送信パケット を前記バスに送信する

ことを特徴とするパケット送受信処理装置。

【請求項2】 請求項1に記載のパケット送受信処理装置において、

前記リンクコア回路によってパケットが受信されてからの時間を計測し、当該 計測時間が予め定められた時間に達すると信号を発生するパケット処理制御タイ マをさらに備え、

前記パケット処理制御回路は、前記パケット処理制御タイマからの信号に応答して前記受信パケットに対する処理を中断し、前記受信パケットに対応する送信パケットを生成した後、前記受信パケットに対する処理を再開することを特徴とするパケット送受信処理装置。

【請求項3】 請求項1に記載のパケット送受信処理装置において、 前記パケット処理制御回路は、

前記受信パケットに対する処理を行っている間は、前記バスを介して外部から 供給されるパケットを受け取ることを禁止するように前記リンクコア回路を制御 する

ことを特徴とするパケット送受信処理装置。

【請求項4】 請求項1に記載のパケット送受信処理装置において、

前記リンクコア回路によって受信された受信パケットの識別情報に基づいて当 該受信パケットを処理すべきか否かを判断し、処理すべきと判断した受信パケットを前記パケット処理制御回路に供給するパケットフィルタ回路をさらに備える ことを特徴とするパケット送受信処理装置。

【請求項5】 請求項4に記載のパケット送受信処理装置において、

前記パケットフィルタ回路は、

前記受信パケットの識別情報、および前記パケット処理制御回路による前記受信パケットに対する処理の結果に基づいて、前記リンクコア回路が次に受信するであろうパケットのヘッダ情報を予測し、当該予測結果と前記リンクコア回路が次に受信したパケットのヘッダ情報とを比較し、この比較結果によって前記リンクコア回路が次に受信したパケットを保持するか否かを決定し、保持することに決定したパケットのみを前記パケット処理制御回路に供給することを特徴とするパケット送受信処理装置。

【請求項6】 請求項1に記載のパケット送受信処理装置において、

前記パケット処理制御回路は、

パケットの送信からパケットの受信、または、パケットの受信からパケットの 送信の一連のトランザクション制御をするトランザクション制御回路と、

パケットの自動分割、および、全てのトランザクション制御を行うパケットエンジン回路と、

パケットの識別情報を含んだヘッダを有し、データフィールドを含まないパケットの作成および送信制御を行うヘッダ制御回路と、

パケットの識別情報を含んだヘッダを有し、データフィールドを含むパケット の作成および送信制御を行うデータフィールド制御回路と、

受信したパケットのデータフィールド処理制御を行うデータ処理回路とを含む ことを特徴とするパケット送受信処理装置。

【請求項7】 請求項6に記載のパケット送受信処理装置において、

前記トランザクション制御回路は、送信パケットの作成から送信まで、または、パケットを受信してから当該受信パケットに対する処理が完了するまでの時間を管理し、前記CPUに結果を出力するとともに、任意の時間で前記CPUによる送信パケットの作成から送信までの時間またはパケットの受信からパケットの処理時間の制御を行う

ことを特徴とするパケット送受信処理装置。

【請求項8】 CPUに接続されたパケット送受信処理装置であって、 送信パケットを生成するパケット処理制御回路と、 /

前記パケット処理制御回路によって生成された送信パケットをバスを介して外部に送信し、かつ、当該バスを介して外部から供給されるパケットを受信するリンクコア回路とを備え、

前記パケット処理制御回路はさらに、前記リンクコア回路によって受信された 受信パケットの処理を行い、当該処理が終了した後、前記受信パケットに対応す る送信パケットを作成して前記リンクコア回路に供給する ことを特徴とするパケット送受信処理装置。

【請求項9】 請求項8に記載のパケット送受信処理装置において、

前記パケット処理制御回路からの送信パケットの識別情報に基づいて、前記リンクコア回路によって受信された受信パケットを処理すべきか否かを判断し、処理すべきと判断した受信パケットを前記パケット処理制御回路に供給するパケットフィルタ回路をさらに備える

ことを特徴とするパケット送受信処理装置。

【請求項10】 CPUに接続されたパケット送受信処理装置であって、

外部からバスを介して供給されるパケットを受信するリンクコア回路と、

要求パケットを作成して前記リンクコア回路に供給し、かつ、前記リンクコア 回路によって受信された受信パケットの処理を行い予め与えられた転送分が終了 するまで連続して次の要求パケットを作成して前記リンクコア回路に供給するパ ケット処理制御回路とを備え、

前記リンクコア回路はさらに、前記パケット処理制御回路からのパケットを前 記バスに送信する

ことを特徴とするパケット送受信処理装置。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】

この発明は、パケット送受信処理装置に関し、さらに詳しくは、IEEE13 94方式のデジタルインターフェイスを用いてパケット単位でデータを転送する ための技術に関する。

[0002]

【従来の技術】

デジタルデータの送受信を行う場合には、一般的にパケットを単位とした通信が利用される。パケットを単位とした通信を行うデジタルインターフェイスの一つにIEEE1394インターフェイスがある。IEEE1394インターフェイスは、アイ・トリプルイー(IEEE)によって規格化が行われている次世代の高速シリアルインターフェイスである。

[0003]

IEEE1394インターフェイスでは、同期パケット通信(Isochronous通信)、非同期パケット通信(Asynchronous通信)の2種類の通信が行える。同期パケット通信は、例えば、デジタルビデオカメラ等のAV機器からのデータの転送のように、リアルタイム性が要求される場合に利用される。一方、非同期パケット通信は、例えば、パーソナルコンピュータやハードディスク等の外部記録装置からのデータ転送のように、リアルタイム性よりも信頼性が要求されるデータの転送に利用される。

[0004]

IEEE1394の非同期パケットには、動作を要求するための「要求パケット」と、要求パケットによって要求された動作の結果を知らせるための「応答パケット」とがある。いずれのパケットに対しても、パケットを受信した場合には、パケットの受信状態を示す認識情報(以下、「ack」という。)を相手機器に返す。要求パケットに対してackによって処理が完了する場合を除いて、要求パケットおよび応答パケットは対にして使用される。要求パケットと応答パケットとによる通信をトランザクションと呼んでいる。

[0005]

ここで、機器Aから機器Bに対して要求パケットを送信する場合の非同期通信のシーケンスを、図14を参照しつつ説明する。

[0006]

まず、機器Aが機器Bに対して要求パケットを送信する。要求パケットを受信

した機器Bは、ackを機器Aに返す。この場合のackとしては、再送要求(ack\_busy)、受信完了で処理中(ack\_pending)、処理完了(ack\_complete)等を示すことができる。ここでは、再送要求(ack\_busy)を機器Aに返すものとする。

[0007]

ack (再送要求)を受信した機器Aは、機器Bに対して要求パケットを再送する。要求パケットを受信した機器Bは、ack (受信完了)を機器Aに返す。

[0008]

ack(受信完了)は、機器Bが要求パケットを処理中であることを示している。したがって、ack(受信完了)を受信した機器Aは、要求パケットに対応した応答パケットが機器Bから送信されるのを待つ。

[0009]

IEEE1394では、要求パケットと応答パケットとを用いた通信において、処理の中断を検出することができるようにタイム・アウトが決められている。すなわち、要求パケットを送信し、処理中であることを示すack(受信完了)を受信してから一定時間経過しても応答パケットを受信しない場合には、何らかの異常により要求パケットによって要求された処理が中断されたと判断する。これによって、要求パケットを送信した機器は次の処理を行うことができる。

[0010]

逆に、要求パケットを受信した機器は、対応する応答パケットをこの一定時間内に送信する必要がある。一定の時間は、初期値として100mgが設定されているが、それぞれの装置で任意に設定することができる。また、処理完了(ack\_complete)を示しているときは、機器は次の処理を行うことができ、応答パケットの送信は行われない。

[0011]

IEEE1394での非同期パケット通信を利用したプロトコルの一つとして、Asynchronous Connectionが知られている。Asynchronous Connectionは、要求パケットを送信するノード(以下、「プロデューサ」という。)と、応答パケットを送信するノード(以下、

「コンスーマ」という。)との間の転送プロトコルであり、図15に示すようなシステムで構成されている。図15に示すシステムにおいては、コントローラ(例えば、セット・トップ・ボックス)は、コンスーマ(例えば、プリンタ)に対してコマンドを発行して、相互に接続(以下、コネクション)する。接続プロトコルは以下に示す通りである。

[0012]

まず、コントローラは、コンスーマのPCR (プラグ・コントロール・レジスタ) にリソースを割り当てる。コンスーマは割り当てたプラグアドレスをコントローラに送信する(1)。

[0013]

次いで、コントローラは、コンスーマのプラグアドレスをプロデューサに与え、プロデューサを初期化する。プロデューサは、プラグアドレスをコントローラに送信する(2)。

[0014]

次いで、コントローラは、プロデューサのプラグアドレスをコンスーマに送信 する(3)。以上でコネクションは完了する。

[0015]

コネクションが完了すると、図16に示すように、コンスーマは、プロデューサから送信されるデータを格納するためのメモリ(以下、セグメント・バッファ領域)を用意して、プロデューサに対して、Lock Request(以下、LRQ)を発行する。これに応答して、プロデューサは、Lock Response(LRS)を送信する(a)。

[0016]

プロデューサは、送信側アプリケーションのメモリ内のアドレスの連続した領域のデータ(以下、セグメント・バッファ領域)をBlock Write Request (BWRQ) パケットによって、コンスーマに送信する。IEEE 1394では、送信パケットのデータフィールドの最大サイズが決められているので、セグメント・バッファ領域が最大サイズよりも大きいときは、分割して送信される。コンスーマは、受信完了でパケット処理中を示すack (ack\_p

ending)をプロデューサに送信し、受信したパケットのアドレスを認識して受信データを受信側アプリケーションのセグメント・バッファ領域に格納する。受信したパケットのデータフィールドをすべてセグメント・バッファ領域に格納した後、受信パケットに対する応答パケットであるWrite Response(WRS)をプロデューサに送信する。プロデューサは上記応答パケットを受信した後、処理完了を示すack(ack\_complete)をコンスーマに送信する(c)。以上のトランザクションを送信側のアプリケーションのセグメント・バッファ領域のデータの送信が完了するまで続ける。これらの処理全体をデータ転送処理とよぶ。

#### [0017]

送信側アプリケーションのデータを全てコンスーマ側のアプリケーションに転送し終わったら、コンスーマに転送が終わったことを示すLock Request (LRQ)を送信する。コンスーマは、Lock Response(LRS)を送信する(d)。このとき、送信側アプリケーションのセグメント・バッファ領域と受信側アプリケーションのセグメント・バッファ領域の先頭アドレスとサイズは同じである。また、プロデューサはセグメント・バッファ領域のデータを先頭から順番に送信してくるため、コンスーマは受信側アプリケーションのセグメント・バッファ領域に受信したパケットのデータフィールドを順番に格納する。

#### [0018]

さらに、Asynchronous Connectionにおいては、図17に示すように、プロデューサは、データ転送処理中にコンスーマからの応答パケットを受信してから、次の要求パケットを2sec以内に送信できないのであれば、その状態を知らせる要求パケットを送信しなければならない(以下、この処理を「ハートビート処理」という。)(C)。

#### [0019]

また、コンスーマは、応答パケットを送信してから 5 s e c 以内に次の要求パケットまたはハートビート処理に関するパケットを受信しないときは、タイム・アウト処理に入ることになる。

[0020]

以上のような処理を行う回路として、図18に示すような回路がある。

[0021]

図18において、バス12aは、IEEE1394シリアルバスであり、その 他端は、他のシステム(ノード)に接続されている。レジスタ31は、バス12 gを介してCPUに接続されている。

[0022]

物理層コントローラ13は、バス12aの初期化、アービトレーション、バイアス電圧の制御等の機能を有している。

[0023]

リンクコア回路14は、物理層コントローラ13を介して、バス12aからのパケットを受信する。また、リンクコア回路14は、受信したパケットに対して誤り検出符号の作成/検出、パケットへの符号の付加、コードの検出(例えば、ackパケットのコード検出)などを行う。さらに、リンクコア回路14は、送信バッファ36からのパケットを、物理層コントローラ13を介してバス12aに出力する。さらに、リンクコア回路14は、パケットの転送に失敗した場合に、そのパケットの転送を再度試みるリトライ機能を有している。

[0024]

送信パケットは、CPUからレジスタ31にヘッダ情報が書かれると、パケット送信回路35に送られ、パケットが作成され、送信バッファ36に格納される。また、パケット送信回路35は、パケット作成時に送信パケットの情報を受信制御回路34に与える。送信バッファ36は、パケット送信回路35からパケットが書き込まれると、これをリンクコア回路14に送る。リンクコア回路14は、物理層コントローラ13を介して、パケットを送信する。

[0025]

一方、受信制御回路34は、リンクコア回路14からパケットを受け取り、そのパケットのヘッダフィールドの内容を解析する。また、受信制御回路34は、送信パケットに対する受信パケットを正確に認識するために、パケット送信回路35から送信パケット情報を入手し、受信パケットのヘッダ情報と比較、解析す

ることでパケットを受信するかを判定する。そして、受信パケットが送信パケットに対するものでないときは受信しないようにリンクコア14を制御する。

[0026]

パケット受信回路33は、受信制御回路34からの受信パケットを制御してパケット受信バッファ32に格納する。パケット受信バッファ32に格納されたパケットは、レジスタ31を介して、CPUによって読み出すことができる。

[0027]

【発明が解決しようとする課題】

IEEE1394では、要求パケットと応答パケットを用いた通信において、 処理の中断を検出することができるようにタイム・アウトが決められている。

[0028]

一方、Asynchronous Connectionにおいては、コンスーマ側のアプリケーションが、受信したパケットのデータを、IEEE1394で規定されている時間内にセグメント・バッファに格納することができなかったときには、コンスーマは受信パケットに対する応答パケットを送信することができない。したがって、プロデューサはタイム・アウトを生じることになる。

[0029]

ところが、Asynchronous Connectionにおいては、タイム・アウトによるプロデューサの処理の終了は規定されていない。このため、プロトコルのシステムが確立できない可能性がある。さらに、受信パケットの処理完了を示すack(受信完了)を転送すると次のトランザクションが開始されるため、トランザクションの制御および受信パケットの処理が複雑になり、システムの確立が困難になる。

[0030]

また、Asynchronous Connectionでは、プロデューサは、コンスーマからの応答パケットを受信してから、次の要求パケットを2sec以内に送信できないのであれば、状態を知らせるためにハートビート処理をする必要がある。一方、コンスーマは、応答パケットを送信してから5sec以内に次の要求パケットまたはハートビート処理に関するパケットを受信しないとき

は、タイム・アウト処理に入ることになる。このように、IEEE1394での 要求パケットと応答パケットを用いた通信に利用されている時間管理とは、別の 時間管理が必要である。

#### [0031]

また、任意の時間にハートビート処理に関するパケットを送受信できるためには、プロデューサ側では、送信パケットの作成・送信に関する処理再開、処理中、処理停止等の時間制御が、コンスーマ側では、受信パケットの処理に関する処理再開、処理中、処理停止等の時間制御が必要である。

#### [0032]

Asynchronous Connectionでは、以上のような機能を有してパケットの送受信ができるパケット送受信処理装置が望まれている。

#### [0033]

#### 【課題を解決するための手段】

この発明の1つの局面に従うと、パケット送受信処理装置は、CPUに接続されたパケット送受信処理装置であって、リンクコア回路と、パケット処理制御回路とを備える。リンクコア回路は、外部からバスを介して供給されるパケットを受信する。リンクコア回路は、また、パケット処理制御回路からの送信パケットをバスに送信する。パケット処理制御回路は、リンクコア回路によって受信された受信パケットに対する処理を行い、受信パケットに対応する送信パケットを作成してリンクコア回路に供給する。

#### [0034]

上記パケット送受信処理装置においては、CPUがトランザクションの処理に関与することがない。したがって、コンスーマ時のトランザクション処理におけるCPUの負荷を軽減でき、処理の高速化を実現できる。

#### [0035]

好ましくは、上記パケット送受信処理装置はさらに、パケット処理制御タイマ を備える。パケット処理制御タイマは、リンクコア回路によってパケットが受信 されてからの時間を計測し、当該計測時間が予め定められた時間に達すると信号 を発生する。上記パケット処理制御回路は、パケット処理制御タイマからの信号 に応答して受信パケットに対する処理を中断し、受信パケットに対応する送信パケットを生成した後、受信パケットに対する処理を再開する。

[0036]

上記パケット送受信処理装置によれば、送信側にトランザクションのタイムアウトを生じさせずに処理を続けることができる。

[0037]

好ましくは、上記パケット処理制御回路は、受信パケットに対する処理を行っている間は、バスを介して外部から供給されるパケットを受け取ることを禁止するようにリンクコア回路を制御する。

[0038]

上記パケット送受信処理装置においては、トランザクション終了まで、次の要求パケットを受け付けないため、トランザクション処理が簡潔になり、シーケンスを簡略化することが可能となる。

[0039]

好ましくは、上記パケット送受信処理装置はさらに、パケットフィルタ回路を備える。パケットフィルタ回路は、リンクコア回路によって受信された受信パケットの識別情報に基づいて当該受信パケットを処理すべきか否かを判断し、処理すべきと判断した受信パケットをパケット処理制御回路に供給する。

[0040]

好ましくは、上記パケットフィルタ回路は、受信パケットの識別情報、およびパケット処理制御回路による受信パケットに対する処理の結果に基づいて、リンクコア回路が次に受信するであろうパケットのヘッダ情報を予測し、当該予測結果とリンクコア回路が次に受信したパケットのヘッダ情報とを比較し、この比較結果によってリンクコア回路が次に受信したパケットを保持するか否かを決定し、保持することに決定したパケットのみをパケット処理制御回路に供給する。

[0041]

上記パケット送受信処理装置によれば、必要な受信パケット、および受信データの連続性を制御することができ、さらに受信パケットに対する適切な送信パケットを作成、送信することが可能となり、必要な複数のトランザクションの処理

を実現できる。

#### [0042]

好ましくは、上記パケット処理制御回路は、トランザクション制御回路と、パケットエンジン回路と、ヘッダ制御回路と、データフィールド制御回路と、データ処理回路とを含む。トランザクション制御回路は、パケットの送信からパケットの受信、または、パケットの受信からパケットの送信の一連のトランザクション制御をする。パケットエンジン回路は、パケットの自動分割、および、全てのトランザクション制御を行う。ヘッダ制御回路は、パケットの識別情報を含んだヘッダを有し、データフィールドを含まないパケットの作成および送信制御を行う。データフィールド制御回路は、パケットの識別情報を含んだヘッダを有し、データフィールドを含むパケットの作成および送信制御を行う。データフィールドを含むパケットの作成および送信制御を行う。データ処理回路は、受信したパケットのデータフィールド処理制御を行う。

#### [0043]

上記パケット送受信処理装置によれば、受信パケットからパケット処理、送信パケットに至るトランザクション処理および、送信パケットから受信パケットの 処理に至るトランザクション処理を効率的に行うことができる。

#### [0044]

好ましくは、上記トランザクション制御回路は、送信パケットの作成から送信まで、または、パケットを受信してから当該受信パケットに対する処理が完了するまでの時間を管理し、CPUに結果を出力するとともに、任意の時間でCPUによる送信パケットの作成から送信までの時間またはパケットの受信からパケットの処理時間の制御を行う。

#### [0045]

上記パケット送受信処理装置によれば、送信パケット作成中、または受信パケット処理中にハートビート等の任意の時間でのパケット処理をすることを可能にすることができる。

#### [0046]

この発明のもう1つの局面に従うと、パケット送受信処理装置は、CPUに接続されたパケット送受信処理装置であって、パケット処理制御回路と、リンクコ

ア回路とを備える。パケット処理制御回路は、送信パケットを生成する。パケット処理制御回路は、また、リンクコア回路によって受信された受信パケットの処理を行い、当該受信パケットに対応するパケットを作成してリンクコア回路に供給する。リンクコア回路は、パケット処理制御回路によって生成されたパケットをバスを介して外部に送信し、かつ、当該バスを介して外部から供給されるパケットを受信する。

#### [0047]

上記パケット送受信処理装置においては、プロデューサ時のトランザクション 処理にCPUが関与することがない。したがって、CPUの負荷を低減し、処理 の高速化を実現できる。

#### [0048]

好ましくは、上記パケット送受信処理装置はさらに、パケットフィルタ回路を備える。パケットフィルタ回路は、パケット処理制御回路からの送信パケットの識別情報に基づいて、リンクコア回路によって受信された受信パケットを処理すべきか否かを判断し、処理すべきと判断した受信パケットをパケット処理制御回路に供給する。

#### [0049]

上記パケット送受信処理装置によれば、必要な受信パケット、および受信データの連続性を制御することができ、さらに受信パケットに対する適切な送信パケットを作成、送信することが可能となり、必要な複数のトランザクションの処理を実現できる。

#### [0050]

この発明のさらにもう1つの局面に従うと、パケット送受信処理装置は、CP Uに接続されたパケット送受信処理装置であって、リンクコア回路と、パケット 処理制御回路とを備える。リンクコア回路は、外部からバスを介して供給される パケットを受信する。リンクコア回路はさらに、パケット処理制御回路からのパ ケットを前記バスに送信する。パケット処理制御回路は、要求パケットを作成し てリンクコア回路に供給する。パケット処理制御回路は、また、リンクコア回路 によって受信された受信パケットの処理を行い予め与えられた転送分が終了する まで連続して次の要求パケットを作成してリンクコア回路に供給する。

[0051]

上記パケット送受信処理装置は、プロデューサに対してもコンスーマに対して も利用できるようにするため、それぞれに必要とされる機能を別回路にすること なく共有化している。これにより、回路規模を小さくすることが可能となる。

[0052]

#### 【発明の実施の形態】

以下、この発明の実施の形態について図面を参照して詳しく説明する。なお、 図中同一または相当部分には同一符号を付し、その説明は繰り返さない。

#### [パケット送受信処理装置]

図1は、この発明の実施の形態によるパケット送受信処理装置の構成を示すブロック図である。図1を参照して、このパケット送受信処理装置1は、バスB1を介して、別の1394システム機器(図示せず)に接続されている。バスB1は、IEEE1394シリアルバスである。また、パケット送受信処理装置1は、バスB3を介してCPU(図示せず)に接続され、DMAバスB2a, B2bを介してDMAコントローラ(図示せず)に接続される。

#### [0053]

そして、パケット送受信処理装置1は、物理層コントローラ13と、リンクコア回路14と、パケットフィルタ回路15と、送受信バッファ16と、送信バッファ17と、パケット受信バッファ18と、送信フィルタ19と、パケット処理制御回路20と、レジスタ21と、パケット処理制御タイマ22と、パケット受信回路23とを備える。

#### [0054]

物理層コントローラ13は、バスB1の初期化、アービトレーション、バイアス電圧の制御などを行う。リンクコア回路14は、物理層コントローラ13を介して、バスB1からのパケットを受信する。また、リンクコア回路14は、受信したパケットに対して誤り検出符号の作成/検出、パケットへの符号の付加、コードの検出(例えば、ackパケットのコード検出)などを行う。さらに、リンクコア回路14は、物理層コントローラ13を介して、パケットをバスB1に出

力する。さらに、リンクコア回路 1 4 は、パケットの転送に失敗した場合に、そのパケットの転送を再度試みるリトライ機能を有する。

#### [0055]

パケットフィルタ回路15は、リンクコア回路14からパケットを受け取り、そのパケットのヘッダフィールドの内容を解析する。そして、解析結果に応じて、そのパケットをパケット受信バッファ18に格納するか、送受信バッファ16に格納するかを選択する。また、解析結果に応じて、パケット処理制御回路20に制御信号CT1を出力する。

#### [0056]

パケット受信回路23は、パケットフィルタ回路15からの受信パケットを制御してパケット受信バッファ18に格納する。パケット受信バッファ18には、プロトコル処理に関係しないパケットが格納される。パケット受信バッファ18に格納されたパケットは、レジスタ21からバスB3を介して、CPUによって読み出すことができる。

#### [0057]

パケット処理制御回路20は、パケットフィルタ回路15からの制御信号CT1に応答して、受信パケットの処理を行う。受信パケットの処理としては、例えば、受信パケットのデータをバスB2aを介してDMAコントローラに送られる受信パケットに対する応答パケットの作成、送信、トランザクションの制御などがある。また、パケット処理制御回路20は、パケット送受信装置1が要求パケットを送信するプロデューサである場合には、DMAコントローラによって読み出され、バスB2bを介して供給されたデータを複数のパケットに分割し、その複数のパケットを送受信バッファ16を介してリンクコア回路14に出力する。複数のパケットは、リンクコア回路14によってバスB1に出力される。

#### [0058]

送信フィルタ19は、レジスタ21からのパケットPK1とパケット処理制御回路20からのパケットPK2とを送信バッファ17に選択的に格納する。送信バッファ17に格納されたパケットは、リンクコア回路14に送られ、リンクコア回路14によってバスB1に出力される。

[0059]

レジスタ21には、Ackコントロール変数21a、tcode変数21b、tl変数21c、source\_ID変数21d、セグメント・バッファ・アドレス変数21eなどが格納される。

[0060]

tcode変数21bは、パケットの種類を示すコードである。パケットの種類としては、例えば、QRRQ(Quadlet Read Request)、BRRQ(Block Read Request)、BWRQ(Block Write Response)などがある。t1変数21cは、トランザクションを識別するためのコードである。tcode変数21bの値およびt1変数21cの値は、格納されるパケットに応じてレジスタ21内で更新される。source\_ID変数21dは、プロデューサのノード番号を示すコードである。セグメント・バッファ・アドレス変数21eは、コンスーマのセグメント・バッファ領域の現在のアドレスを示す。すなわち、受信パケットでの期待されるdestination\_offsetアドレスの値を示す。セグメント・バッファ・アドレス変数21eは、コンスーマのセグメント・バッファ・アドレス変数21eは、コンスーマのセグメント・バッファ・アドレス変数21eは、コンスーマのセグメント・バッファ・アドレス変数21eは、コンスーマのセグメント・バッファ・アドレスにデータがすべて格納されるとレジスタ21内で更新される。

[0061]

パケット処理制御タイマ22は、パケット処理制御回路20からの制御信号CT2bに応答して時間の計測を開始し、計測時間が所定の時間に達すると制御信号CT2aをパケット処理制御回路20に出力する。具体的には、パケット送受信装置1が要求パケットを送信するプロデューサである場合には、パケット処理制御回路20がBWRQパケットの作成を開始してからの時間を計測する。そして、計測時間が予め設定された時間に達すると、レジスタ21を介してCPUへ知らせる。これに対するCPUからの命令に応答して制御信号CT2aをパケット処理制御回路20に出力する。また、パケット送受信装置1が要求パケットを受信するコンスーマである場合には、パケットの受信から受信完了までの処理時間、および、トランザクション終了から次のトランザクション開始までの時間を

計測する。

[0062]

図2は、図1に示したパケット処理制御回路20の内部構成を示すブロック図である。図2を参照して、パケット処理制御回路20は、パケットエンジン回路50と、トランザクション制御回路51と、ヘッダ制御回路52と、データフィールド制御回路53と、データ処理回路54とを含む。

[0063]

パケットエンジン回路 5 0 は、パケットの自動分割、および全てのトランザクション制御を行う。トランザクション制御回路 5 1 は、パケットの送信からパケットの受信あるいはパケットの受信からパケットの送信の一連のトランザクション制御をする。ヘッダ制御回路 5 2 は、パケットの識別情報を含んだヘッダを有し、データフィールドを含まないパケットの作成および送信制御を行う。データフィールド制御回路 5 3 は、パケットの識別情報を含んだヘッダを有し、データフィールドを含むパケットの作成および送信制御を行う。データ処理回路 5 4 は、受信したパケットのデータフィールド処理制御を行う。

[0064]

次に、バスB1から受信されるパケットのフォーマットを、図3-図7に示す。図中、斜線の領域はリザーブ領域を示す。具体的には、図3-図7は、それぞれ、BWRQ(Block Write Request)パケット、QWRQ(Quadlet Write Request)パケット、WRS(Write Reponse)パケット、BRRQ(Block Read Request)パケット、BRRS(Block Read Response)パケットのフォーマットを示す。

[0065]

なお、バスB1に出力されるパケットのフォーマットも図3-図7に示されるフォーマットと同一である。

[0066]

また、リンクコア回路14に書き込む際のパケットのフォーマットを、図8-図12に示す。すなわち、図1に示した送信バッファ17、送受信バッファ16 およびパケット処理制御回路20は、いずれも、図8-図12に示されるフォーマットでパケットをリンクコア回路14に書き込む。なお、図3-図7に示したフォーマットは、それぞれ、図8-図12に示したフォーマットに対応する。

[0067]

リンクコア回路14は、パケットをバスB1に出力する際には、header \_\_CRCやdata\_CRCなどのチェックコードを計算し、その計算結果を示すフィールドを図8-図12に示したフォーマットのパケットに追加する。このようにして、リンクコア回路14によって、図3-図7に示されるフォーマットのパケットが作成される。

[0068]

また、リンクコア回路14は、パケットをバスB1から受信した際には、図3 -図7に示されるフォーマットに含まれるheader\_CRC領域やdata \_CRC領域を参照することにより、CRCによる誤り検出を行う。

[パケット通信システム]

次に、以上のように構成されたパケット送受信処理装置を用いたパケット通信 システムについて説明する。

[0069]

図13は、図1に示したパケット送受信処理装置を用いたパケット通信システムの構成を示すブロック図である。図13を参照して、このシステムでは、プロデューサとしてDVC(デジタルビデオカメラ)300を、コンスーマとしてプリンタ200を備える。

[0070]

DVC300は、パケット送受信処理装置3と、メモリ40と、伸長回路41 と、画像処理部42と、D/A変換器43と、EVF(Electric View Finder)44とを含む。

[0071]

パケット送受信処理装置3は、図1に示したパケット送受信処理装置と同様の 構成を有する。メモリ40には、DVC300によって撮影された画像データが 所定の高能率符号化方式によって圧縮されて格納されている。伸長回路41は、 メモリ40から読み出された圧縮画像データを伸長する。画像処理部42は、伸長回路41からの画像データに対して、EVF44で表示するために必要な画像処理を施す。D/A変換器43は、画像処理部42によって画像処理が施された画像データをアナログ画像データに変換する。EVF44は、D/A変換器43からのアナログ画像データを表示する。

[0072]

メモリ40に格納されたデータは、EVF44に表示されるか、または、パケット送受信処理装置3からバスB1を介してプリンタ200に送られる。EVF44に表示する場合には、圧縮された画像データを伸張回路41によって伸張し、EVF44で表示するために必要な画像処理を画像処理部42にて行い、D/Aコンバータ43を経てEVF44に表示する。

[0073]

プリンタ200は、パケット送受信処理装置2と、メモリ26と、プリンタコントローラ27と、ドライバ28と、プリンタヘッド29とを含む。

[0074]

パケット送受信処理装置 2 は、図1に示したパケット送受信処理装置と同様の構成を有する。メモリ26には、パケット送受信処理装置 2 からのデータが記録される。プリンタコントローラ27は、パケット送受信処理装置 2 からメモリ26へのデータの記録を制御する。また、プリンタコントローラ27は、プリンタヘッド29およびドライバ28を制御して、メモリ26に記録された画像データをプリントする。

[0075]

なお、IEEE1394方式に従ってデータを転送する場合には、その転送速度によりパケットの転送可能な最大ペイロードサイズが規定されているため、転送速度によりパケットのデータフィールドの最大サイズは規定されている。この実施の形態では、S400(400Mbit/sec)とし、1パケットでの転送可能なデータ長は2048バイトである。

[0076]

次に、以上のように構成されたパケット通信システムの動作について説明する

。ここでは、DVC300から8kbyteのデータをプリンタ200に転送する場合について説明する。なお、説明の便宜のため、タイムアウトが生じない場合、コンスーマ(プリンタ200)側にタイムアウトが生じた場合、プロデューサ(DVC300)側にタイムアウトが生じた場合、に分けて説明する。

#### <タイムアウトが生じない場合>

まず、プロデューサであるDVC300において、BWRQパケットを作成するために、メモリ40からのデータ(2kbyte)がパケット送受信処理装置3内のパケット処理制御回路20(図1)に送られる。パケット処理制御回路20において作成されたBWRQパケットは、送受信バッファ16(図1)からリンクコア回路14(図1)、物理層コントローラ13(図1)を介してバスB1から送信される。

#### [0077]

次いで、コンスーマであるプリンタ200において、バスB1を介して受信したパケット(BWRQ)は、パケット送受信処理装置2内の物理層コントローラ13(図1)からリンクコア回路14(図1)を介してパケットフィルタ回路15(図1)に入力される。

#### [0078]

パケットフィルタ回路15(図1)は、レジスタ21(図1)に格納されたt
code変数21b、source\_ID変数21d、およびセグメント・バッファ・アドレス変数21eの値を参照する。そして、受信したパケット(BWRQ)に含まれるtcode領域の値、source\_ID領域の値、destination\_offset領域の値と、レジスタ21(図1)に格納されたtcode変数21b、source\_ID変数21d、およびセグメント・バッファ・アドレス変数21eの値とを比較することによって、受信したパケット(BWRQ)が実行中のデータ転送処理シーケンスに関連するものであるかどうかを判定する。判定の結果、データ転送処理シーケンスに関連していれば、送受信バッファ16(図1)に格納し、制御信号CT1をパケット処理制御回路20(図1)に与える。関連していなければ、パケット受信バッファ18に格納する。ここでは、送受信バッファ16(図1)に格納する。なお、セグメント・バッフ

ァ・アドレス変数 2 1 e は格納されるパケットによってレジスタ 2 1 内で更新される。

[0079]

そして、パケット処理制御回路20(図1)は、パケットフィルタ回路15(図1)からの制御信号CT1に応答して、レジスタ21(図1)内のAckコントロール変数21a(図1)の値を"Ack\_busy"に設定する。これ以降、リンクコア回路14は、Ackコントロール変数21aの値"Ack\_busy"を参照して、バスB1からパケットを受信することなく、そのパケットに対して、"Ack\_busy"の値を有するAckパケットを返す。

[0080]

受信したパケット(BWRQ)は、パケットフィルタ回路15(図1)から送受信バッファ16(図1)を介してパケット処理制御回路20(図1)に入力される。パケット処理制御回路20(図1)で処理されたデータは、バスB2a(図1)を介してメモリ26に格納される。

[0081]

メモリ26にデータを格納した後、パケット処理制御回路20(図1)は、レジスタ21のsource\_\_ID変数21d, t1変数21cを参照して、WRSパケットのヘッダとデータとを生成する。WRSパケットは、送信フィルタ19(図1)に入力される。そして、送信フィルタ19(図1)から送信バッファ17(図1)、リンクコア回路14(図1)、物理層コントローラ13(図1)を介して、バスB1から送信される。

[0082]

次いで、プロデューサであるDVC300において、バスB1を介してパケット送受信処理装置3に入力された受信パケット(WRSパケット)は、物理層コントローラ13(図1)、リンクコア回路14(図1)を通してパケットフィルタ回路15に入力される。

[0083]

パケットフィルタ回路15は、レジスタ21に格納されたtcode変数21 bおよびt1変数21cの値を参照する。そして、受信したパケット(WRSパ ケット)に含まれるtcode領域の値およびt1領域の値と、レジスタ21に格納されたtcode変数21bおよびt1変数21cの値とを比較することによって、受信したパケット(WRSパケット)が実行中のデータ転送処理シーケンスに関連するものであるかどうかを判定する。判定の結果、データ転送処理シーケンスに関連していれば、制御信号CT1をパケット処理制御回路20(図1)に与える。関連していなければ、パケット受信バッファ18に格納する。

#### [0084]

そして、パケット処理制御回路 20(図1)は、このWRSパケットに対する 応答として、 "Ack\_complete"の値を有するackパケットを作成 し、バスB1に送信する。

#### [0085]

次いで、コンスーマであるプリンタ200において、パケット送受信処理装置2内のパケットフィルタ回路15(図1)は、バスB1を介して受信されたackパケットの内容を解析し、その結果をレジスタ21(図1)に出力するとともに、制御信号CT1をパケット処理制御回路20(図1)に出力する。この制御信号CT1に応答して、パケット処理制御回路20(図1)は、レジスタ21内のAckコントロール変数21aの値を解除する。これにより、パケットの受信が可能となる。すなわち、パケット処理制御回路20は、制御信号CT1に応答してトランザクションを終了し、次のトランザクションを開始する。

#### [0086]

次いで、プロデューサであるDVC300において、次のトランザクションを 開始するために、BWRQパケットが作成され、送信される。

#### [0087]

以上の処理を4回実行することによって、8kbyteのデータがコンスーマ であるプリンタ200に送信される。

#### [0088]

以上のように、このパケット送受信処理装置を用いたパケット通信システムにおいては、トランザクションの管理にCPUは関与していない。したがって、トランザクション処理におけるCPUの負荷を軽減することができる。このことは

、IEEE1394に準拠した高速なデータ転送を実現するのに役立つ。

[0089]

また、パケットフィルタ回路15は、データ転送処理シーケンスに関連しないパケットをフィルタリングするため、データ転送処理の実行が途中で中断されることがない。したがって、データ転送処理の実行途中で他のトランザクションに分岐するなどの余分な制御をする必要がなく、パケット処理制御回路20による処理制御が容易になる。これにより、パケット送受信処理装置1-3の構成を簡素化することができる。

<コンスーマ(プリンタ200)側にタイムアウトが生じた場合>

プロデューサ(DVC300)側のタイム・アウトは、100msに設定されている。コンスーマ(プリンタ200)側のパケット送受信処理装置2におけるパケット処理制御タイマ22のタイムアウトは、90msに設定されている。

[0090]

データ転送処理が開始されると、プロデューサであるDVC300において、BWRQパケットを作成するために、メモリ40からのデータ(2kbyte)がパケット送受信処理装置3内のパケット処理制御回路20(図1)に送られる。そして、パケット処理制御回路20(図1)で作成された送信パケット(BWRQ)は、送受信バッファ16(図1)からリンクコア回路14(図1)、物理層コントローラ13(図1)を通してバスB1から送信される。

[0091]

次いで、コンスーマであるプリンタ200において、バスB1から受信したパケット(BWRQ)が、パケット送受信処理装置2内の物理層コントローラ13(図1)、リンクコア回路14(図1)を介してパケットフィルタ回路15(図1)に入力される。パケット処理制御回路20(図1)は、パケットフィルタ回路15(図1)からの制御信号CT1に応答して、レジスタ21(図1)内のAckコントロール変数21a(図1)の値を"Ack\_busy"に設定する。また、制御信号CT1に応答して、パケット処理制御回路20(図1)は、パケット処理制御タイマ22に対して制御信号CT2bを出力する。この制御信号CT2bに応答してパケット処理制御タイマ22が起動し、時間の計測を開始する

。受信パケット(BWRQ)は、パケットフィルタ回路15(図1)から送受信 バッファ16(図1)を介してパケット処理制御回路20(図1)に入力される 。パケット処理制御回路20(図1)で処理されたデータは、メモリ26に格納 される。

#### [0092]

ここで、パケット処理制御回路20(図1)が受信パケットを90ms以内に 処理できなかった場合には、パケット処理制御タイマ22(図1)は、タイムア ウトを検出してCPUに知らせる。CPUは、レジスタ21(図1)を介して、 パケット処理制御回路20(図1)にパケット処理一時停止命令、およびパケッ ト送信命令を送る。

#### [0093]

パケット処理制御回路20(図1)は、CPUからのパケット処理一時停止命令を受けて、現在処理しているパケット処理を一時中断する。さらに、送信命令を受けて、パケット処理制御回路20(図1)は、受信パケットの処理を一時停止した状態で、WRSパケットのヘッダとデータとを生成する。生成されたWRSパケットは、送信フィルタ19(図1)、送信バッファ17(図1)、リンクコア回路14(図1)、物理層コントローラ13(図1)を介してバスB1から送信される。

#### [0094]

次いで、プロデューサであるDVC300において、バスB1からパケット送受信処理装置3に入力された受信パケット(WRS)は、物理層コントローラ13(図1)、リンクコア回路14(図1)を通してパケットフィルタ回路15(図1)に入力される。そして、このWRSパケットに対する応答として、"Ack\_complete"の値を有するackパケットをバスB1に送信する。

#### [0095]

次いで、コンスーマであるプリンタ200において、CPUはパケット処理再 実行命令をパケット処理制御回路20(図1)に送る。これにより、一時停止し ていたパケットの処理が再開される。すなわち、パケット送受信処理装置2内の パケットフィルタ回路15(図1)は、受信されたackパケットの内容を解析 し、その結果をレジスタ21 (図1) に出力するとともに、制御信号CT1をパケット処理制御回路20 (図1) に出力する。パケット処理制御回路20 (図1) は、この制御信号CT1に応答して、トランザクションを終了し、一時停止中の受信パケット処理を再実行する。

[0096]

プロデューサであるDVC300は、WRSパケットを受信することによって次のトランザクションを開始する。しかし、コンスーマであるプリンタ200は、パケット処理を再実行している間、レジスタ21(図1)内のAckコントロール変数21a(図1)の値を"Ack\_busy"に設定することによって、プロデューサからの要求パケットを受信しない処理を行う。そして、受信パケットの処理の再実行が終了すると、パケット処理制御回路20は、レジスタ22のAckコントロール変数21aの値を解除し、要求パケットの受信を可能にする。コンスーマであるプリンタ200は、この時点から要求パケットを受信する。そして、さらに3回のトランザクション処理を行い、8kbyteのデータをメモリ26に格納して、転送が終了する。

[0097]

以上のように、このパケット送受信処理装置においては、プロデューサ(DVC300)に対してタイムアウトを生じさせることなくパケット処理を行うことができる。したがって、複数のトランザクションを制御する必要がなく、パケット処理制御回路20、および処理シーケンスを簡素化することができる。

<プロデューサ(DVC300)側にタイムアウトが生じた場合>

ここでは、DVC300におけるパケット処理制御タイマ22のタイムアウトは、2secに設定されているものとする。

[0098]

まず、プロデューサであるDVC300において、BWRQパケットを作成するために、メモリ40からデータ(2kbyte)がパケット処理制御回路20(図1)に送られる。パケット処理制御回路20(図1)は、送信パケット(BWRQ)の作成を開始するとともにパケット処理制御タイマ22(図1)に対して制御信号CT2bを出力する。この制御信号CT2bに応答して、パケット処

理制御タイマ22(図1)は時間の計測を開始する。

[0099]

送信パケット(BWRQ)の作成を開始してから2sec経過しても送信パケットが(BWRQ)送信されない場合、パケット制御タイマ22は、タイム・アウトを検出してこれをCPUに知らせるとともに、パケット処理制御回路20(図1)に制御信号CT2aに応答して、パケット処理制御回路20(図1)は、送信パケット(BWRQ)の作成を中断する。

[0100]

予め設定した時間(2sec)を経過したので、CPUは、ハートビート処理を実行する。ハートビート処理が終了すると、CPUは、レジスタ21の所定のフィールドを設定する。これに応じて、パケット処理制御回路20(図1)は、送信パケット(BWRQ)の作成を再開する。

[0101]

パケット処理制御回路20(図1)で作成された送信パケット(BWRQ)は、送受信バッファ16(図1)、リンクコア回路14(図1)、物理層コントローラ13(図1)を通してバスB1から送信される。

[0102]

次いで、コンスーマであるプリンタ200において、バスB1から受信したパケット(BWRQ)が、パケット送受信処理装置2内の物理層コントローラ13(図1)、リンクコア回路14(図1)を介してパケットフィルタ回路15(図1)に入力される。

[0103]

パケット処理制御回路20(図1)は、パケットフィルタ回路15(図1)からの制御信号CT1に応答して、レジスタ21(図1)内のAckコントロール変数21a(図1)の値を"Ack\_busy"に設定する。受信されたパケット(BWRQ)は、パケットフィルタ回路15(図1)、送受信バッファ16(図1)を介してパケット処理制御回路20(図1)に入力される。パケット処理回路20(図1)で処理されたデータは、メモリ26に格納される。メモリ26にデータを格納した後、パケット処理制御回路20(図1)は、WRSパケット

のヘッダとデータとを生成する。生成されたWRSパケットは、送信フィルタ19(図1)、送信バッファ17(図1)、リンクコア回路14(図1)、物理層コントローラ13(図1)を介してバスB1から送信される。

#### [0104]

次いで、プロデューサであるDVC300において、バスB1からパケット送受信処理装置3に入力された受信パケット(WRS)が物理層コントローラ13 (図1)、リンクコア回路14(図1)を通してパケットフィルタ回路15(図1)に入力される。そして、このWRSパケットに対する応答として、"Ack\_complete"の値を有するackパケットをバスB1に送信する。

#### [0105]

次いで、コンスーマであるプリンタ200において、パケット送受信処理装置 2内のパケットフィルタ回路15(図1)は、受信されたackパケットの内容 を解析し、その結果をレジスタ21(図1)に出力するとともに、制御信号CT 1をパケット処理制御回路20(図1)に出力する。パケット処理制御回路20 (図1)は、レジスタ21(図1)内のAckコントロール変数21a(図1) の値を解除する。これにより、パケットの受信が可能となる。このように、パケット処理制御回路20(図1)は、制御信号CT1に応答してトランザクション を終了し、次のトランザクションを開始する。

#### [0106]

次いで、プロデューサであるDVC300において、次のトランザクションを 開始するために、要求パケット(BWRQ)が作成され、送信される。

#### [0107]

以上の処理を4回実行することにより、8kbyteのデータが、コンスーマであるプリンタ200に送信される。

#### [0108]

以上のように、このパケット送受信処理装置においては、パケット作成からの時間管理をし、任意にパケットの作成、一時停止、再開ができるために、トランザクション実行中の任意の時間に別のトランザクション処理(ハートビート処理等)を行うことができる。

[0109]

【発明の効果】

この発明によるパケット送受信処理装置では、パケットの送受信に関するトランザクションにCPUが関与することがないためデータ転送の高速化が図れる。

[0110]

また、パケットの作成から送信まで、およびパケット受信から処理終了の時間 管理およびパケット処理の一時停止、再開を任意に行うことができるので、トラ ンザクション中の別のトランザクションを割り込ませることが容易にできる。

[0111]

また、受信パケット処理中のパケット受信を制御することができるため、処理 を簡潔にできる。

[0112]

また、受信パケット処理中でも受信パケットに対する送信パケットを送信できるため、シーケンスの自由度を向上することができる。

【図面の簡単な説明】

【図1】

この発明の実施の形態によるパケット送受信処理装置の構成を示すブロック図である。

【図2】

図1に示したパケット処理制御回路の構成を示すブロック図である。

【図3】

図1に示したリンクコア回路からバスに出力されるBWRQ(Block Write Request)パケットのフォーマットを示す図である。

【図4】

図1に示したリンクコア回路からバスに出力されるQWRQ(Quadlet Write Request)パケットのフォーマットを示す図である。

【図5】

図1に示したリンクコア回路からバスに出力されるWRS (Write Reponse) パケットのフォーマットを示す図である。

【図6】

図1に示したリンクコア回路からバスに出力されるBRRQ(BlockR e a d Request) パケットのフォーマットを示す図である。

【図7】

図1に示したリンクコア回路からバスに出力されるBRRS (Block Read Response) パケットのフォーマットを示す図である。

【図8】

図1に示したリンクコア回路に書き込まれるBWRQ(Block Write Request)パケットのフォーマットを示す図である。

【図9】

図1に示したリンクコア回路に書き込まれるQWRQ(Quadlet Write Request)パケットのフォーマットを示す図である。

【図10】

図1に示したリンクコア回路に書き込まれるWRS (Write Reponse) パケットのフォーマットを示す図である。

【図11】

図1に示したリンクコア回路に書き込まれるBRRQ(Block Read Request) パケットのフォーマットを示す図である。

【図12】

図1に示したリンクコア回路に書き込まれるBRRS (Block Read Response) パケットのフォーマットを示す図である。

【図13】

図1に示したパケット送受信処理装置を用いたパケット通信システムの構成を 示すブロック図である。

【図14】

IEEE1394の非同期転送のシーケンスを示す図である。

【図15】

Asynchronous Connectionのシステムの構成を示す図である。

【図16】

Asynchronous Connectionのシーケンスを示す図である。

【図17】

Asynchronous Connectionのシーケンスを示す図である。

【図18】

従来のパケット送受信処理装置の構成を示す図である。

【符号の説明】

- 1-3 パケット送受信処理装置
- 13 物理層コントローラ
- 14 リンクコア回路
- 15 パケットフィルタ回路
- 16 送受信バッファ
- 17 送信バッファ
- 18 パケット受信バッファ
- 19 送信フィルタ
- 20 パケット処理制御回路
- 21 レジスタ
- 22 パケット処理制御タイマー

【書類名】 図面

## 【図1】



【図2】



## 【図3】

Block write request transmit format

| spd            | tl rt tcode pri |  |  |
|----------------|-----------------|--|--|
| destination_ID |                 |  |  |
| destinati      | on_offset       |  |  |
| data_length    | extended_tcode  |  |  |
| フ゛ロック          | <b>プデータ</b>     |  |  |
|                | (必要なら)t゙¤       |  |  |

### 【図4】

## Quadlet write request transmit format

| spd                | t1 | rt | tcode | pri |  |
|--------------------|----|----|-------|-----|--|
| destination_ID     |    |    | -     |     |  |
| destination_offset |    |    |       |     |  |
| quadlet_data       |    |    |       |     |  |

## 【図5】

Write response receive format

| destination_ID | tl    | rt | tcode | pri     |
|----------------|-------|----|-------|---------|
| source_ID      | rcode |    |       |         |
|                |       |    |       |         |
| spd            |       |    |       | ackSent |

## 【図6】

## Block read request transmit format

| spd            | tl        | rt | tcode | pri |
|----------------|-----------|----|-------|-----|
| destination_ID |           |    |       |     |
| destinati      | on_offset |    |       | ]   |
| data_length    |           |    |       |     |

## 【図7】

Block read response receive format

| destination_ID | t1             | rt    | tcode      | pri     |  |
|----------------|----------------|-------|------------|---------|--|
| source_ID      |                |       |            |         |  |
| destinati      | on_offset      |       |            |         |  |
| data_length    | extended_tcode |       |            |         |  |
| フ゛ロックテ゛ータ      |                |       |            |         |  |
|                | (必要なら)         | <br>) | <br>!<br>! |         |  |
| spd            |                |       |            | ackSent |  |

## 【図8】

Write request for data block packet format

| 先頭<br>31       |                |             |             | 0   |
|----------------|----------------|-------------|-------------|-----|
| destination_ID | t1             | rt          | tcode       | pri |
| source_ID      |                |             |             | ,   |
| destinati      | on_offse       | t           | •           | _   |
| data_length    | extended_tcode |             |             |     |
| heade          | r_CRC          |             |             |     |
| data_          | field          |             |             | ·   |
|                | (必要なり          | 5) t`¤      | <br>!<br>!  |     |
| data           | _CRC           | <del></del> | <del></del> |     |
|                | <u> </u>       | <u></u>     | <del></del> | 末尾  |

【図9】

Write request for data quadlet packet format

| 先與<br><u>31</u> |           |       |       | 0   |
|-----------------|-----------|-------|-------|-----|
| destination_ID  | t1        | rt    | tcode | pri |
| source_ID       |           |       |       |     |
| destinati       | on_offset | ,<br> |       | ]   |
| quadle          | t_data    |       |       |     |
| heade           | r_CRC     |       |       |     |
|                 |           |       |       | 末尾  |

【図10】

Write response packet format



【図11】

Read request for data block packet format

| 先頭<br><u>31</u> |           |      |             | 0   |
|-----------------|-----------|------|-------------|-----|
| destination_ID  | t1        | rt   | tcode       | pri |
| source_ID       |           |      |             |     |
| destinati       | on_offset |      |             |     |
| data_length     | exte      | ende | d_tcode     | 9   |
| heade           | r_CRC     |      |             |     |
|                 |           |      | <del></del> | 末尾  |

【図12】

Read response for data block packet format

| 先頭 <u>31                                    </u> |          |          |             | 0   |
|--------------------------------------------------|----------|----------|-------------|-----|
| destination_ID                                   | tl       | rt       | tcode       | pri |
| source_ID                                        |          |          | <del></del> |     |
| destinati                                        | on_offse | et       |             |     |
| data_length                                      | ex       | tende    | d_tcode     | 9   |
| heade                                            | r_CRC    |          |             |     |
| data_                                            | field    |          |             |     |
|                                                  | (必要な)    | 5) t " ¤ | !<br>!      |     |
| data                                             | _CRC     |          | l           |     |
|                                                  |          |          |             | 末尾  |

7

【図13】



【図14】



【図15】



【図16】



【図17】



【図18】



【書類名】 要約書

【要約】

【課題】 Asynchronous Connectionに適したパケット送受信処理装置を提供する。

【解決手段】 コンスーマ側のパケット処理制御回路20が受信パケットを 所定時間内に処理できなかった場合、パケット処理制御タイマ22は、タイムア ウトを検出してCPUに知らせる。CPUは、レジスタ21を介して、パケット 処理制御回路20にパケット処理一時停止命令、パケット送信命令を送る。パケ ット処理制御回路20は、現在処理しているパケット処理を一時中断し、WRS パケットのヘッダとデータとを生成する。WRSパケットは、バスB1からプロ デューサ側に送信される。これにより、プロデューサに対してタイムアウトを生 じさせることなくパケット処理を行うことができる。

【選択図】 図1

#### 出願人履歷情報

識別番号

[000005821]

1. 変更年月日

1990年 8月28日

[変更理由]

新規登録

住 所

大阪府門真市大字門真1006番地

氏 名

松下電器産業株式会社